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SYSTEM AND METHOD FOR FORCING AN SRAM INTO 
A KNOWN STATE DURING POWER -UP 

TECHNICAL FIELD OF THE INVENTION 

5 

The present invention is directed, in general, to processing 
systems and, more specifically, to a static random access memory 
(SRAM) containing an embedded program that is accessed at power-up. 

10 Si BACKGROUND OF THE INVENTION 

^ The continuing demand for faster, smaller, cheaper, lower- 

J J power computers requires that state-of-the-art microprocessors 
execute instructions in the minimum amount of time, space, cost and 

15 J* energy. Conventional personal computers (PCs) usually execute a 
start-up routine in which the microprocessor executes a boot 
program stored in a BIOS ROM (or "flash" EPROM) on the motherboard 
of the PC. The BIOS program then loads the operating system 
software from a disk drive into main memory. Generally, accessing 

2 0 and executing the boot program in the BIOS ROM is comparatively 

slow. The BIOS ROM itself occupies board space and has only a 
limited use after start-up. The BIOS ROM also adds cost to the PC. 

1 
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It would be more advantageous if a microprocessor could boot 
up using a static random access memory (SRAM) , such an on-chip SRAM 
in the Level 1 (LI) cache or an SRAM in either an external or an 
on-chip Level 2 (L2) cache. Then, after the boot-up routine was 
completed, the microprocessor could reuse the area of the SRAM in 
which the boot -up routine code was stored as a cache area or 
dedicated on-chip memory. Unfortunately, the cells in an SRAM 
"wake up" after a Power-On-Reset (POR) in an unknown state. Thus, 
the SRAM cannot be used to store, for example, a BIOS program or a 
self -test program that is accessed and executed at start-up. 

Therefore, there is a need in the art for improved processing 
system designs that eliminate or minimize the need for an external 
BIOS ROM that is accessed by a microprocessor at start-up. More 
particularly, there is a need for a microprocessor having an on- 
chip SRAM cache capable of storing an embedded program that is 
executed by the microprocessor immediately after power-up. 



2 
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SUMMARY OF THE INVENTION 

The limitations inherent in the prior art described above are 
overcome by the present invention which provides a biasing (or 
initializing) circuit that may implemented in each cell of a SRAM 
device, thereby biasing every cell in the SRAM device to 
individually selectable known states after power is applied to the 
SRAM device. Thus, a start-up (or boot-up) program may be embedded 
in the SRAM device that is immediately available after a power-on- 
reset occurs. 

In an advantageous embodiment of the present invention, there 
is provided a static random access memory (SRAM) device capable of 
storing a program that is accessible when the SRAM device is 
powered up. The SRAM device comprises a plurality of storage 
cells, each of the storage cells comprising: 1) a data latch having 
an input and an output, wherein the data latch comprises a) a first 
inverter having an input coupled to the first I/O line and an 
output coupled to the second I/O line and b) a second inverter 
having an input coupled to the second I/O line and an output 
coupled to the first I/O line; and 2) a biasing circuit capable of 
forcing at least one of the first and second I/O lines to a known 
logic state when power is applied to the SRAM device, wherein the 
known logic state comprises a portion of the program. 

3 
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As used above, the term "data" should be broadly construed to 
include instruction bits as well as actual data bits and, in the 
case of a cache, also includes tags bits, valid bits, and/or dirty- 
bits . 

According to one embodiment of the present invention, the 
biasing circuit initially applies power only to the first inverter. 

According to this embodiment, the initial application of power 
only to the first inverter forces the first inverter output to a 
Logic 1 state. 

Further according to this embodiment, the biasing circuit 
subsequently applies power to the second inverter. 

Still according to this embodiment of the invention, the 
subsequent application of power to the second inverter forces the 
second inverter output to a Logic 0 state . 

According to another embodiment of the present invention, the 
biasing circuit initially applies power only to the second 
inverter. 

According to this embodiment of the invention, the initial 
application of power only to the second inverter forces the second 
inverter output to a Logic 1 state. 

Further according to this embodiment, the biasing circuit 
subsequently applies power to the first inverter. 
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According to this embodiment of the invention, the subsequent 
application of power to the first inverter forces the first 
inverter output to a Logic 0 state. 

According to yet another embodiment of the present invention, 
the biasing circuit comprises a grounding circuit selectively 
connected by a programmable contact to one of the first inverter 
output and the second inverter output, wherein the grounding 
circuit is temporarily enabled after power is applied to the SRAM 
device, thereby grounding one of the first inverter output and the 
second inverter output and forcing the data latch to the known 
logic state. 

An initializing on-chip SRAM according to the principles of 
the present invention would be useful to store the microcode and 
other programmable blocks that are currently ROM programmed. This 
would provide a capability of field reprogramming the 
microprocessor to fix errors, to add features, or to improve 
functionality. 

Advantageously, an SRAM device according to the principles of 
the present invention allows a decryption program or decryption 
codes to be embedded in a processor. Since the decryption program 
or decryption codes are on-chip and may be erased before the SRAM 
is accessed by other software programs, the decryption program 
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and/or codes are more secure than when stored in conventional 
storage devices. 

An SRAM device according to the principles of the present 
invention also provides advantages with respect to newer processor 
designs that remove the ISA bus common in many legacy designs. 
Removing the ISA bus frequently requires additional hardware to 
connect the boot ROM. Replacing the boot ROM with an SRAM 
according to the present invention eliminates this extra connection 
circuitry. 

In a mult i -way set associative cache, it may be advantageous 
to implement SRAM cells according to the principles of the present 
invention in only one way of the cache and/or in only the 
instruction cache. This may save on area, power, and/or 
complexity. Many boot -up programs can be written in much less than 
four kilobytes (4K) , thereby allowing the boot-up program to fit in 
one 4K way of a 16 kilobyte 4-way set associative instruction cache 
typical of many current microprocessors. 

An SRAM device according to the principles of the present 
invention also provides advantages in single-chip micro-controller 
designs that presently contain both an embedded RAM and an embedded 
ROM. By eliminating the on-chip ROM, the present invention would 
provide more space for additional RAM. 
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The foregoing has outlined rather broadly the features and 
technical advantages of the present invention so that those skilled 
in the art may better understand the detailed description of the 
invention that follows. Additional features and advantages of the 
invention will be described hereinafter that form the subject of 
the claims of the invention. Those skilled in the art should 
appreciate that they may readily use the conception and the 
specific embodiment disclosed as a basis for modifying or designing 
other structures for carrying out the same purposes of the present 
invention. Those skilled in the art should also realize that such 
equivalent constructions do not depart from the spirit and scope of 
the invention in its broadest form. 

Before undertaking the DETAILED DESCRIPTION OF THE INVENTION, 
it may be advantageous to set forth definitions of certain words 
and phrases used throughout this patent document : the terms 
"include" and "comprise," as well as derivatives thereof, mean 
inclusion without limitation; the term "or/' is inclusive, meaning 
and/or; the phrases "associated with" and "associated therewith," 
as well as derivatives thereof, may mean to include, be included 
within, interconnect with, contain, be contained within, connect to 
or with, couple to or with, be communicable with, cooperate with, 
interleave, juxtapose, be proximate to, be bound to or with, have, 
have a property of, or the like; and the term "controller" means any 

7 
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device, system or part thereof that controls at least one 
operation, such a device may be implemented in hardware, firmware 
or software, or some combination of at least two of the same. It 
should be noted that the functionality associated with any 
particular controller may be centralized or distributed, whether 
locally or remotely. Definitions for certain words and phrases are 
provided throughout this patent document, those of ordinary skill 
in the art should understand that in many, if not most instances, 
such definitions apply to prior, as well as future uses of such 
defined words and phrases. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

For a more complete understanding of the present invention, 
reference is now made to the following descriptions taken in 
conjunction with the accompanying drawings, in which: 

FIGURE 1 is a block diagram of an exemplary processing system, 
which includes an integrated microprocessor according to one 
embodiment of the present invention; 

FIGURE 2 illustrates an exemplary SRAM cell for use in the LI 
cache or the L2 cache in the exemplary microprocessor according to 
one embodiment of the present invention; 

FIGURE 3 illustrates an exemplary SRAM cell for use in the LI 
cache or the L2 cache in the exemplary microprocessor according to 
another embodiment of the present invention; and 

FIGURE 4 is a flow diagram illustrating the operation of the 
exemplary CPU according to one embodiment of the present invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

FIGURES 1 through 4, discussed below, and the various 
embodiments used to describe the principles of the present 
invention in this patent document are by way of illustration only 
and should not be construed in any way to limit the scope of the 
invention. Those skilled in the art will understand that the 
principles of the present invention may be implemented in any 
suitably arranged processing system. 

FIGURE 1 is a block diagram of processing system 10, which 
includes integrated microprocessor 100, according to one embodiment 
of the present invention. Integrated microprocessor 10 0 comprises 
central processing unit (CPU) 105, which may have dual integer and 
dual floating point execution units, separate load/store and branch 
units. CPU 105 also comprises LI cache 106, which contains SRAM 
cells which may be biased (or initialized) after a power reset 
according to the principles of the present invention. 

Microprocessor 100 also comprises graphics unit 110, system 
memory controller 115, and L2 cache 12 0, which is shared by CPU 105 
and graphics unit 110. Graphics unit 110, system memory 

controller 115, and L2 cache 120 may be integrated onto the same 
die as microprocessor 105. Bus interface unit 125 connects 
CPU 105, graphics unit 110, and L2 cache 120 to memory 

10 
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controller 115. Bus interface unit 125 also may be integrated onto 
the same die as microprocessor 105. In an advantageous embodiment 
of the present invention, L2 cache 12 0 also may contain SRAM cells 
which may be biased (or initialized) after a power reset according 
to the principles of the present invention. 

Integrated memory controller 115 bridges microprocessor 100 to 
system memory 14 0, and may provide data compression and/ or 
decompression to reduce bus traffic over external memory bus 145 
which preferably, although not exclusively, has a RAMbus™ , fast 
SDRAM or other type protocol. Integrated graphics unit 110 
provides TFT, DSTN, RGB, or other types of video output to drive 
display 150. 

Bus interface unit 125 connects microprocessor 100 through I/O 
interface 130 to PCI bridge 155, which has a conventional 
peripheral component interconnect (PCI) bus interface on PCI 
bus 160 to one or more peripherals, such as sound card 162, LAN 
controller 164, and disk drive 166, among others. Bus interface 
unit 125 also connects fast serial link 180 and relatively slow I/O 
port 185 to microprocessor 100 (via I/O interface 130 and PCI 
bridge 155) . Fast serial link 180 may be, for example, an 
IEEE 1394 bus (i.e., "Firewire") and/or a universal serial bus 
("USB") . I/O port 185 is used to connect peripherals to 
microprocessor 100, such as keyboard 190 and/or a mouse. In some 

11 
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embodiments, PCI bridge 155 may integrate local bus functions such 
as sound, disk drive control, modem, network adapter, and the like. 

In one embodiment of the present invention, LI cache 106 may 
comprise a plurality of SRAM cells that may be biased (or 
initialized) to a particular logic state (Logic 1 or Logic 0) 
during a power reset. In one embodiment, LI cache 106 may comprise 
a 16 kilobyte LI instruction (I) cache that is single-ported 4-way 
associative, with 2 pending misses. LI cache 106 also may comprise 
a 16 kilobyte LI data (D) cache that is non-blocking, dual -ported 
(one load port and one store/fill port) , 4-way associative, with 4 
pending misses. Both the data and instruction portions of LI 
cache 106 may be indexed with the linear address and physically 
tagged with the TLB (translated) address. In response to LI 
misses, L2 cache 120 transfers an entire cache line (32 
bytes/256 bits) in one cycle with a seven clock access latency for 
LI misses that hit in L2 cache 120. 

In one embodiment of the present invention, L2 cache 12 0 also 
may comprise a plurality of SRAM cells that may be biased (or 
initialized) to a particular logic state during a power reset. L2 
cache 120 may be an 8-way associative and 8-way interleaved. Each 
interleave supports one LI (code/data) miss per cycle, and either 
one LI store or one L2 fill per cycle. Portions or all of two of 
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the eight ways may be locked down for use by graphics 
controller 110. 

FIGURE 2 illustrates exemplary SRAM cell 300 for use in LI 
cache 106 in CPU 105 or L2 cache 120 according to one embodiment of 
the present invention. SRAM cell 300 comprises CMOS inverters 305 
and 310 , n-type MOS transfer gate transistors 315 and 320, column 
line 330, column line 331, row line 335, and p-type MOS 
transistors 340 and 345. SRAM cell 300 further comprises 

programmable contacts 350 and 355, either of which may be connected 
during fabrication to transistor 340 or transistor 345, as shown. 

In the embodiment shown, programmable contact 350 is connected to 
transistor 340 and programmable contact 355 is connected to 
transistor 345. As will be explained below in greater detail, the 
connection of programmable contacts 350 and 355 determines whether 
SRAM cell 300 initially comes up with a Logic 1 or Logic 0 state 
after power is applied. 

CMOS inverter 305 comprises p-type transistor 306 and n-type 
transistor 3 07 and CMOS inverter 310 comprises p-type 
transistor 311 and n-type transistor 312. The output line 321 of 
inverter 305 is connected to the input of inverter 310 and the 
output line 316 of inverter 310 is connected to the input of 
inverter 3 05, forming a latch for data storage. The power ground 
reference is supplied to inverters 305 and 310 through the drain 
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connection on transistors 307 and 312. Inverters 305 and 310 are 
connected to the +V power supply rail through the source 
connections of transistors 3 06 and 311 and either power 
transistor 340 or power transistor 345. Transistor 306 is 
connected to the +V power supply transistor through programmable 
contact 350 and transistor 311 is connected to the +V power supply 
transistor through programmable contact 355. 

Transistors 315 and 320 are open when row line 335 is a low 
voltage (or Logic 0) , providing high impedances to column line 33 0 
and column line 331 . When row line 335 is a high voltage 
or logic 1, transistor 315 closes to transfer the state of column 
line 330 to the input of inverter 305 or to transfer the output of 
inverter 310 to column line 33 0, and transistor 320 closes to 
transfer the output of inverter 305 to column line 331 or to 
transfer the state of column line 331 to the input of inverter 310. 

Immediately after power is applied (or reset) in LI cache 106 
or L2 cache 120 (i.e., at time t = to) , the EARLY POWER signal and 
the LATE POWER signals are driven to high (i.e., to Logic 1) , 
effectively disconnecting the +V power supply rail from 
inverters 305 and 310. At the same time, row line 335 is driven 
high, thereby turning "ON" transistors 315 and 320, and column 
lines 330 and 331 are driven low (i.e., to Logic 0) . Since output 
line 321 of inverter 305 is essentially shorted to column line 331 

14 
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by transistor 320, output line 321 is discharged to ground (I.E., 
Logic 0) . Since output line 316 of inverter 310 is essentially 
shorted to column line 330 by transistor 315, output line 316 also 
is discharged to ground (i.e., Logic 0). SRAM cell 300 is held in 
this state for a short period of time to allow internal output 
lines 321 and 316 to discharge to a Logic 0. 

At a later time (t = tl) , row line 335 is driven low, thereby 
open-circuiting transistors 315 and 320. At this point, output 
line 316 and output line 320 remain at Logic 0, but are capable of 
being changed. Column lines 33 0 and 331 are also released and are 
no longer held to Logic 0. 

At a later time (t = t2) , the EARLY POWER signal goes low 
(i.e., to Logic 0), closing transistor 340 and connecting the +V 
power to inverter 305. Since the input to inverter 305 is Logic 0 
(from output line 316 of inverter 3 05) , output line 321 of 
inverter 305 goes to Logic 1. 

At a later time (t - t3) , the LATE POWER signal goes low at 
the gate of transistor 345. Transistor 345 closes and the +V power 
is supplied to inverter 310. Since the input to inverter 310 is 
Logic 1 (from output line 321 of inverter 305) , the output of 
inverter 310 goes to Logic 0, which then is inverted by 
inverter 305, reinforcing the Logic 1 already on output line 321 of 
inverter 305. Thus, the initial programmed Logic 1 output of 
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inverter 3 05 is maintained as a Logic 1 by the latch comprised of 
inverters 305 and 310. 

Data is written to SRAM cell 300 when row line 335 is driven 
high, thereby closing transistor 315 and transferring the value on 
column line 33 0 to the input of inverter 3 05 for storage and also 
closing transistor 32 0 and transferring the value on column 
line 331 for storage. The values on column lines 33 0 and 331 are 
always complementary. SRAM cell 300 is read when column lines 330 
and 331 are floating and row line 335 drives the gates of 
transistor 320 and transistor 315 high. This closes transistor 320 
and transfers the Logic 1 or Logic 0 stored on output line 321 of 
inverter 305 to column line 331. Transistor 315 is also closed, 
which transfers the Logic 0 or Logic 1 stored on output line 316 of 
inverter 310 to column line 330. 

If Logic 0 is desired as the initial power-up output from SRAM 
cell 300, programmable contact 350 is connected to transistor 345 
and programable contact 355 is connected to transistor 340. The 
EARLY POWER and LATE POWER signals and the +V power supply are 
applied as before. This time, however, the +V power is first 
applied to inverter 310, causing it output to go to Logic 1. The 
subsequent application of the +V power to inverter 3 05 then causes 
the output of inverter to go to Logic 0. This is the initial state 
of SRAM cell 300. 



DOCKET NO. P04056 



PATENT 



Since the fabrication process can connect contacts 350 and 355 
to either the EARLY POWER transistor 340 or the LATE POWER 
transistor 345, each cell in LI cache 106 or L2 cache 120 may be 
programmed as a Logic 1 or a Logic 0 after power up. In this 
manner, a boot -up program may be stored in LI cache 106 or L2 
cache 12 0 and executed after power is applied to CPU 105 and 
microprocessor 100. Advantageously, this on-chip boot-up program 
may comprise, among other things a decryption program or decryption 
codes, which may be erased before the SRAM is accessed by other 
software programs. 

FIGURE 3 illustrates exemplary SRAM cell 450 for use in LI 
cache 106 in CPU 105 or L2 cache 120 according to another 
embodiment of the present invention. SRAM cell 450 comprises 
inverters 455 and 460, n-type MOS transistors 465, 470, and 495, 
column line 48 0, column line 481, row line 485, and programmable 
connects 490 and 491. Transistor 495 is configured so that its 
drain is connected to ground, its gate is connected to a reset 
signal (reset) which is normally Logic 0 (OFF) , and its source is 
connected to one side of programmable connects 490 and 491. The 
other side of programmable connect 490 is connected to the output 
of inverter 455 and the input of inverter 460. The other side of 
programmable connect 491 is connected to the output of inverter 460 
and the input of inverter 455. 
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Depending upon the desired initial output for the latch formed 
with inverters 455 and 460, programmable connect 490 or 
programmable connect 491 is installed during fabrication. If a 
Logic 1 is desired initially at column line 481 when row line 485 
is high, programmable connect 491 is removed. Otherwise, if a 
Logic 0 is desired as the initial power-up state, programmable 
connect 490 is removed. 

When power is initially applied, column line 480, column 481 
and row line 485 are Logic 0. Shortly after power is applied, the 
RESET signal goes to Logic 1 on the gate of transistor 495, which 
shorts the drain of transistor 495 to ground. If programmable 
connect 4 91 has been removed and programmable connect 490 remains, 
programmable connect 490 pulls the output of inverter 455 (and the 
input of inverter 460) to ground (Logic 0) . Inverter 4 60 inverts 
the Logic 0 on its input to a Logic 1 on its output. This is the 
value stored in SRAM cell 450 after power up. Inverter 455 inverts 
the Logic 1 from inverter 460 to a Logic 0. Once the RESET returns 
to Logic 0, transistor 495 opens and the latch formed by 
inverters 455 and 460 maintains a Logic 1 at the output of 
inverter 460. 

In an similar manner, SRAM cell 450 could have powered-up to 
a Logic 0 by removing programmable connect 4 90 and leaving 
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programmable connect 491 connected between the drain of 
transistor 495 and the output of inverter 460. 

As similarly described for SRAM cell 300, when row line 485 is 
high, the output of the latch formed by inverters 455 and 460 is 
transferred to column lines 481 and 480 during a read operation and 
the value on column lines 480 and 481 can be forced into the input 
of the latch during a write operation. The initial programmed 
stored state of the latch formed by inverters 455 and 4 60 is 
maintained until column lines 480 and 481 cause the latch to switch 
to the other state. 

FIGURE 4 depicts flow diagram 500, which illustrates the 
operation of the exemplary CPU 105 according to one embodiment of 
the present invention. First, a power-on- reset event occurs, 
providing a short reset signal which enables the LI cache (or L2 
cache) initialization process to begin (process step 505) . In one 
embodiment, LI cache 10 6 (or L2 cache 12 0) powers up with 
individual SRAM cells biased to values required for the boot -up 
program, as described above with respect to FIGURES 2 and 3 
(process step 510) . Next, CPU 105 begins execution of the boot-up 
program stored in LI cache 106 or L2 cache 120 (process 515) . 

Although the present invention has been described in detail, 
those skilled in the art should understand that they can make 
various changes, substitutions and alterations herein without 
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departing from the spirit and scope of the invention in its 
broadest form. 
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WHAT IS CLAIMED IS: 



1 1. A static random access memory (SRAM) device capable of 

2 storing a program that is accessible when said SRAM device is 

3 powered up, said SRAM device comprising a plurality of storage 

4 cells, each of said storage cells comprising: 

5 a data latch having a first input /output (I/O) line and 

6 ^ a second I/O line, said data latch comprising: 

7 "2 a first inverter having an input coupled to said 

8 first I/O line and an output coupled to said second I/O line; 

9 1% and 

10 a second inverter having an input coupled to said 

11 [I second I/O line and an output coupled to said first I/O line; 

13 pi a biasing circuit capable of forcing at least one of said 

14 first and second I/O lines to a known logic state when power is 

15 applied to said SRAM device, wherein said known logic state 

16 comprises a portion of said program. 

1 2 . The SRAM device as set forth in Claim 1 wherein said 

2 biasing circuit initially applies power only to said first 

3 inverter. 
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1 3 . The SRAM device as set forth in Claim 2 wherein said 

2 initial application of power only to said first inverter forces 

3 said first inverter output to a Logic 1 state. 

1 4 . The SRAM device as set forth in Claim 3 wherein said 

2 biasing circuit subsequently applies power to said second inverter. 

1 5. The SRAM device as set forth in Claim 4 wherein said 

2 %2 subsequent application of power to said second inverter forces said 

3 N second inverter output to a Logic 0 state. 

1 %J 6 . The SRAM device as set forth in Claim 1 wherein said 

2 ^ biasing circuit initially applies power only to said second 

3 inverter. 

1 7. The SRAM device as set forth in Claim 6 wherein said 

2 initial application of power only to said second inverter forces 

3 said second inverter output to a Logic 1 state . 

1 8 . The SRAM device as set forth in Claim 7 wherein said 

2 biasing circuit subsequently applies power to said first inverter. 
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1 9. The SRAM device as set forth in Claim 8 wherein said 

2 subsequent application of power to said first inverter forces said 

3 first inverter output to a Logic 1 state. 

1 10. The SRAM device as set forth in Claim 1 wherein said 

2 biasing circuit comprises a grounding circuit selectively connected 

3 by a programmable connect to one of said first inverter output and 

4 said second inverter output, wherein said grounding circuit is 

5 ^3 temporarily enabled after power is applied to said SRAM device, 

6 H thereby grounding one of said first inverter output and said second 

7 ^: inverter output and forcing said second I/O line to said known 

8 % ^ logic state. 



23 



DOCKET NO. P04056 PATENT 

11. A data processor comprising a central processing unit 
(CPU) capable of executing a boot -up program when power is applied 
to said CPU, said CPU comprising: 

a static random access memory (SRAM) device capable of 
storing said boot-up program, said SRAM device comprising a 
plurality of storage cells capable of storing bits of said boot-up 
program, each of said storage cells comprising: 

a data latch having an input and an output, said 
data latch comprising: 

a first inverter having an input coupled to 
said first I/O line and an output coupled to said second 
I/O line; and 

a second inverter having an input coupled to 
said second I/O line and an output coupled to said first 
I/O line; and 

a biasing circuit capable of forcing at least one 
of said first and second I/O lines to a known logic state when 
power is applied to said SRAM device. 

12. The data processor as set forth in Claim 11 wherein said 
biasing circuit initially applies power only to said first 
inverter . 
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1 13. The data processor as set forth in Claim 12 wherein said 

2 initial application of power only to said first inverter forces 

3 said first inverter output to a Logic 1 state. 

1 14 . The data processor as set forth in Claim 13 wherein said 

2 biasing circuit subsequently applies power to said second inverter. 

1 P 15. The data processor as set forth in Claim 14 wherein said 

2 subsequent application of power to said second inverter forces said 

3 ]h second inverter output to a Logic 0 state. 

1 l A 16. The data processor as set forth in Claim 11 wherein said 

2 i: biasing circuit initially applies power only to said second 

3 zz inverter. 

1 17. The data processor as set forth in Claim 16 wherein said 

2 initial application of power only to said second inverter forces 

3 said second inverter output to a Logic 1 state. 

1 18. The data processor as set forth in Claim 17 wherein said 

2 biasing circuit subsequently applies power to said first inverter. 
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19. The data processor as set forth in Claim 18 wherein said 
subsequent application of power to said first inverter forces said 
first inverter output to a Logic 1 state. 

20. The data processor as set forth in Claim 11 wherein said 
biasing circuit comprises a grounding circuit selectively connected 
by a programmable connect to one of said first inverter output and 
said second inverter output, wherein said grounding circuit is 
temporarily enabled after power is applied to said SRAM device, 
thereby grounding one of said first inverter output and said second 
inverter output and forcing said second I/O line to said known 
logic state . 
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1 21. For use in a storage cell in a static random access 

2 memory (SRAM) device, the storage cell having an input and an 

3 output and comprising 1) a first inverter having an input coupled 

4 to the storage cell input and an output coupled to the storage cell 

5 output and 2) a second inverter having an input coupled to the 

6 storage cell output and an output coupled to the storage cell 

7 input, a method of forcing the storage cell output to a known logic 

8 n state when power is applied to the SRAM device comprising the step 

9 % t of : 

10 initially applying power only to one of the first 

11 ^ inverter and the second inverter, wherein the initial application 

12 „. of power only to one of the first inverter and the second inverter 

13 I .j-j forces a selected one of the first inverter output and the second 

14 s5 ™ inverter output to a Logic 1 state. 

1 22. The method as set forth in Claim 21 including the further 

2 step of subsequently applying power to the initially unpowered one 

3 of the first inverter and the second inverter, wherein the 

4 subsequent application of power to the initially unpowered one of 

5 the first inverter and the second inverter forces the output of the 

6 unselected one of the first inverter output and the second inverter 

7 output to a Logic 0 state. 
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SYSTEM AND METHOD FOR FORCING AN SRAM INTO 
A KNOWN STATE DURING POWER -UP 



ABSTRACT OF THE DISCLOSURE 



There is disclosed a static random access memory (SRAM) device 
that stores an embedded program that is accessible when the SRAM 
device is powered up. The SRAM device comprises a plurality of 
storage cells, each of the storage cells comprises a data latch 
having an input and an output, wherein the data latch comprises 
a) a first inverter having an input coupled to the first 1/0 line 
and an output coupled to the second I/O line, and b) a second 
inverter having an input coupled to the second I/O line and an 
output coupled to the first I/O line. The storage cell also 
comprises a biasing circuit that forces at least one of the first 
and second I/O lines to a known logic state when power is applied 
to the SRAM device. The known logic state comprises one bit in the 
embedded program. 
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